public class 合并两个有序数组 {
    public static void merge(int[] nums1, int m, int[] nums2, int n) {
        int i = m - 1, j = n - 1;
         int p = nums1.length - 1;

          while (i >= 0 && j >= 0) {
               if (nums1[i] > nums2[j]) {
                nums1[p] = nums1[i];
                i--;
            } else {
                nums1[p] = nums2[j];
                j--;
            }
            p--;
        }

        while (j >= 0) {
            nums1[p] = nums1[j];
            j--;
            p--;
        }
    }

    public static void main(String[] args) {
        int nums1[] = {1, 2, 3, 0, 0, 0};
        int[] nums2 = {2,5,6};
        merge(nums1,3,nums2,3);
    }
}
